package com.lfy.kcat.content.domain.vo;

import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
import cn.idev.excel.annotation.ExcelProperty;
import com.lfy.kcat.content.domain.Dramas;
import io.github.linpeilie.annotations.AutoMapper;
import lombok.Data;

import java.io.Serial;
import java.io.Serializable;
import java.util.Date;


/**
 * 短剧管理视图对象 dramas
 *
 * @author leifengyang
 * @date 2025-09-04
 */
@Data
@ExcelIgnoreUnannotated
@AutoMapper(target = Dramas.class)
public class DramasVo implements Serializable {

    @Serial
    private static final long serialVersionUID = 1L;

    /**
     * 短剧ID
     */
    @ExcelProperty(value = "短剧ID")
    private Long dramaId;

    /**
     * 短剧标题
     */
    @ExcelProperty(value = "短剧标题")
    private String title;

    /**
     * 副标题
     */
    @ExcelProperty(value = "副标题")
    private String subTitle;

    /**
     * 封面图URL
     */
    @ExcelProperty(value = "封面图URL")
    private String cover;

    /**
     * 海报图URL
     */
    @ExcelProperty(value = "海报图URL")
    private String poster;

    /**
     * 预告片URL
     */
    @ExcelProperty(value = "预告片URL")
    private String trailerUrl;
    /**
     * 预告片信息流URL
     */
    private String trailerInfoflowUrl;
    /**
     * 简介
     */
    @ExcelProperty(value = "简介")
    private String description;

    /**
     * 剧情介绍
     */
    @ExcelProperty(value = "剧情介绍")
    private String storyLine;

    /**
     * 导演，多个用逗号分隔
     */
    @ExcelProperty(value = "导演，多个用逗号分隔")
    private String director;

    /**
     * 编剧，多个用逗号分隔
     */
    @ExcelProperty(value = "编剧，多个用逗号分隔")
    private String screenwriter;

    /**
     * 制作公司
     */
    @ExcelProperty(value = "制作公司")
    private String productionCompany;

    /**
     * 发布日期
     */
    @ExcelProperty(value = "发布日期")
    private Date releaseDate;

    /**
     * 总集数
     */
    @ExcelProperty(value = "总集数")
    private Long totalEpisodes;

    /**
     * 当前集数
     */
    @ExcelProperty(value = "当前集数")
    private Long currentEpisodes;

    /**
     * 平均每集时长(秒)
     */
    @ExcelProperty(value = "平均每集时长(秒)")
    private Long episodeDuration;

    /**
     * 总时长(秒)
     */
    @ExcelProperty(value = "总时长(秒)")
    private Long totalDuration;

    /**
     * 语言
     */
    @ExcelProperty(value = "语言")
    private String language;

    /**
     * 地区
     */
    @ExcelProperty(value = "地区")
    private String region;

    /**
     * 年份
     */
    @ExcelProperty(value = "年份")
    private Long year;

    /**
     * 是否完结：0连载中，1已完结
     */
    @ExcelProperty(value = "是否完结：0连载中，1已完结")
    private Long isFinished;

    /**
     * 是否VIP专享：0否，1是
     */
    @ExcelProperty(value = "是否VIP专享：0否，1是")
    private Long isVip;

    /**
     * 是否新剧：0否，1是
     */
    @ExcelProperty(value = "是否新剧：0否，1是")
    private Long isNew;

    /**
     * 是否热播：0否，1是
     */
    @ExcelProperty(value = "是否热播：0否，1是")
    private Long isHot;

    /**
     * 是否推荐：0否，1是
     */
    @ExcelProperty(value = "是否推荐：0否，1是")
    private Long isRecommended;

    /**
     * 画质：SD/HD/FHD/4K
     */
    @ExcelProperty(value = "画质：SD/HD/FHD/4K")
    private String quality;

    /**
     * 年龄分级：G/PG/PG-13/R
     */
    @ExcelProperty(value = "年龄分级：G/PG/PG-13/R")
    private String ageRating;

    /**
     * 播放次数
     */
    @ExcelProperty(value = "播放次数")
    private Long playCount;

    /**
     * 点赞数
     */
    @ExcelProperty(value = "点赞数")
    private Long likeCount;

    /**
     * 评论数
     */
    @ExcelProperty(value = "评论数")
    private Long commentCount;

    /**
     * 分享数
     */
    @ExcelProperty(value = "分享数")
    private Long shareCount;

    /**
     * 收藏数
     */
    @ExcelProperty(value = "收藏数")
    private Long collectionCount;

    /**
     * 追剧数
     */
    @ExcelProperty(value = "追剧数")
    private Long followCount;

    /**
     * 评分
     */
    @ExcelProperty(value = "评分")
    private Long ratingScore;

    /**
     * 评分人数
     */
    @ExcelProperty(value = "评分人数")
    private Long ratingCount;

    /**
     * 状态：0下架，1上架，2审核中
     */
    @ExcelProperty(value = "状态：0下架，1上架，2审核中")
    private Long status;

    /**
     * 审核状态：0待审核，1通过，2拒绝
     */
    @ExcelProperty(value = "审核状态：0待审核，1通过，2拒绝")
    private Long auditStatus;

    /**
     * 审核拒绝原因
     */
    @ExcelProperty(value = "审核拒绝原因")
    private String auditReason;

    /**
     * 排序顺序
     */
    @ExcelProperty(value = "排序顺序")
    private Long sortOrder;


}
